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TECHNICAL FIELD 

The present invention relates to monotonic sequence number generation for use by 
distributed data processing and in particular to monotonic sequence number generation for 
use by distributed database-related applications in a highly available and low latency manner. 
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BACKGROUND 

In present business environments, many information systems exist to process 
transaction information. For example, certain banking information systems may utilize 
transaction information to track transactions initiated by account holders. A banking 
information system may store transaction information in a database. Furthermore, the 
5 banking information system may utilize transaction numbers to provide order to database 
actions. The banking information system may assign an ever-increasing (monotonic) 
sequence of numbers to database actions, so that their order may be retained and processing 
of the actions may occur in an ordered manner. For example, the banking information system 
may utilize transaction numbers to ensure that an electronic transfer of funds does not occur 
10 before a deposit transaction is completed. 

The concept of utilizing transaction numbers is clearly applicable to a very large range 
of data processing applications in addition to banking information systems. For example, 
many business to business information systems may require sequence numbering to manage 
purchase orders, delivery arrangements, invoicing, and payment information via extensive 

15 databases. Broadly speaking, the provision of sequence numbers may be thought of as a form 
of time stamping. Of course, there are numerous applications of time stamping in many 
industries. Accordingly, it shall be further appreciated that the sequence numbering process 
is applicable to many applications beyond applications related to financial or commercial 
environments. In general, any application that orders a significant amount of data objects 

20 may utilize sequence number generation. Distributed applications especially benefit from 
sequence number generation. 

Sequence numbering is a relatively simply process to implement upon a single 
processor system. However, it is evident that most practical applications of sequence 
numbers require scalability, i.e. the sequence numbering may be employed up to an arbitrary 
25 number of logical nodes which are usually distributed across a communication medium or 
system fabric. To achieve scalibility, various mechanisms may be employed, such as 
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determining which process maintains the current sequence number; which process is 
incrementing the number; which process is retaining a master list of sequence numbers; and 
the like. To implement these tasks in a distributed manner in a multi-node environment, the 
respective processors located at the various nodes allocate a portion of processing time to 
5 threads responsible for these overhead mechanisms. Additionally, an amount of signaling 
occurs over the communication medium for similar allocation to overhead mechanisms. 
When these mechanisms are implemented in software, the overhead processing and 
communication protocol signaling are significant. By allocating a significant portion of 
system resources to the overhead tasks, milliseconds of delay are introduced which 
10 significantly reduces the scalability of the system. In fact, delays of several milliseconds may 
cause negative scaling, i.e. coordinating the functionality over several nodes may actually 
cause a reduction in processing capacity. 

Similarly, hardware implementations of the monotonic sequence number generation 
proved problematic. Hardware implementations have involved placing a device in a system 
15 fabric accessible by the various processors by interfaces. In this environment, latency is 
reduced. However, the price of reducing latency in this implementation is reduced 
availability. Specifically, this implementation creates a single point of failure that may cause 
the entire system to malfunction. 
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SUMMARY OF THE INVENTION 

The present invention is directed to a system and method which provides a monotonic 
sequence number generation that is highly available and possesses minimal latency. The 
architecture of the present invention involves establishing at least a primary generator and a 
secondary generator. Applications that utilize transaction numbering to order data may 
5 initiate a call in software to obtain a sequence number. The software call utilizes an interface 
to bypass ordinary network or communication channel protocols. The interface, defined by a 
hardware or firmware implementation device, preferably generates a sequence number 
request to the primary unit. After receiving the sequence number request, the primary 
sequence number generator determines a next sequence number in a monotonic manner. The 

10 primary sequence number updates its memory to reflect that the determined sequence number 
has been utilized. The primary sequence number generator forwards the determined sequence 
number to the secondary sequence number generator. The secondary sequence number 
generator updates its memory to reflect that the determined sequence number has been 
utilized. The secondary sequence number generator forwards the determined sequence 

15 number to the initial hardware implementation device. Finally, the hardware implementation 
device returns the sequence number to the appropriate application process. 

It is a further aspect of the present invention to provide sequence number generation 
in a manner that is robust against failure. Since the secondary generator forwards the 
determined sequence number to the hardware implementation device, the secondary generator 

20 maintains a record of the last sequence number utilized by an application. Occasionally, the 
primary unit may become unavailable due to hardware difficulties or communication link 
failure. If this occurs, the underlying architecture may readjust by reassigning the secondary 
generator as the primary generator. Similarly, the underlying architecture may assign a new 
secondary generator. By doing so, the current sequence number is not lost upon failure of the 

25 primary sequence number generator. Future sequence requests may be forwarded to the new 
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primary generator, thereby increasing availability. Secondly, the architecture may perform 
the adaptation in a manner that is transparent to application processes. 

The foregoing has outlined rather broadly the features and technical advantages of the 
present invention in order that the detailed description of the invention that follows may be 
5 better understood. Additional features and advantages of the invention will be described 

hereinafter which form the subject of the claims of the invention. It should be appreciated by 
those skilled in the art that the conception and specific embodiment disclosed may be readily 
utilized as a basis for modifying or designing other structures for carrying out the same 
purposes of the present invention. It should also be realized by those skilled in the art that 
1 0 such equivalent constructions do not depart from the spirit and scope of the invention as set 
forth in the appended claims. 
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BRIEF DESCRIPTION OF THE DRAWING 

For a more complete understanding of the present invention, reference is now made to 
the following descriptions taken in conjunction with the accompanying drawing, in which: 

FIGURE 1 comprises a simplified system architecture and signal flow to illustrate the 
present invention; 

FIGURE 2 comprises a redundant system architecture to illustrate the present 
invention; 

FIGURE 3 illustrates processing steps associated with initialization of a highly 
available sequence number generation architecture; 

FIGURE 4 illustrates a light-weight call by an application process to obtain a 
sequence number and associated underlying processing steps; and 

FIGURE 5 depicts a block diagram of a computer system which is adapted to use the 
present invention. 
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DETAILED DESCRIPTION 

Turning now to the drawing, FIGURE 1 illustrates a simplified signaling progression 
associated with sequence number generation. An application process at node C may generate 
a sequence number (SN) request. Firmware at node C generates a SN message with the ID of 
node A thereby causing the request to be routed to node A. Node A responds to the request 
5 by creating an SN response comprising the ID of node B, thereby causing the SN response to 
be routed to node B. After receipt, node B forwards the request comprising the ID of node C, 
thereby routing the SN response to its ultimate destination, node C. The firmware initiates a 
direct memory access (DMA) to place the received response in a memory location accessible 
f by the originating application process. 

10 It is an advantage of the present invention to facilitate the embodiment of sequence 

number generation in a wide variety of hardware and/or firmware implementations. By way 
of example and without limitation, the sequence numbering in the node system of FIGURE 1 
may be implemented by adapter cards located at nodes A, B, and C. The implementation of 
the present invention is not limited to adapter cards. For example, the present invention may 

15 by implemented in host/appliance software, firmware, ASICs, fabric elements (e.g. 

augmenting a switch implementation) or any combination thereof. It shall be appreciated that 
any further discussion of adapter cards or firmware refers broadly to all of the preceding 
implementations . 

In FIGURE 1 , the adapter cards may be employed to provide replicated fabrics. In 
20 this exemplary embodiment, each node may comprise two cards. In normal operation, node 
C forwards a request to node A. Node A may increment the present value, DMA the 
incremented value to a memory location in its host processor system, and forward the value 
to node B. Node B may DMA the value to a memory location in its host processor system 
and forward the result to C. If the operating card on node A becomes unaccessible for some 
25 reason (card malfunction, switch failure, cable failure, and/or the like), failure over to the 

other card may occur instead of changing the primary and secondary designations. Since the 
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incremented value is stored in the memory of the host systems, it is sufficient to reinitialize to 
the other cards. Accordingly, this embodiment provides an alternative recovery mechanism. 
However, it shall be appreciated that this configuration permits recovery either through DMA 
operations or failure to the other node. It is not necessary to restrict recovery to only one of 
5 these mechanisms. 

The SN representation may comprise an arbitrarily large number of bits. In a 
preferred embodiment, the SN representation comprises 48-bits. Obviously, the sequence 
numbering space associated with a bit-limited representation is finite. Accordingly, the 
sequence number generation is not monotonic in a strict mathematical sense. However, it is 
10 estimated that normal database operation in connection with 64-bit sequence numbering 
would require years to exhaust the attendant sequence numbering space. Accordingly, the 
48-bit or 64-bit embodiments are sufficient to establish the desired ordering functionality. 

The present invention preferably utilizes pipelining to deliver sequence number 
requests. Pipelining involves a distinction between strong ordering and weak ordering. In 

1 5 strong ordering, sequence numbers are assigned monotonically in response to the arrival of 
sequence number requests. Additionally, strong ordering involves delivering the sequence 
numbers in the same order as the sequence number request arrivals. In weak ordering, 
sequence numbers are also assigned monotonically in response to the arrival of sequence 
number requests. However, weak ordering does not require that the sequence number 

20 response values be delivered in order according to the request arrivals. Pipelining may be 
utilized if node C comprises numerous processors. By utilizing weak ordering, pipelining 
allows numerous sequence number requests to be processed concurrently without having 
node C wait until individual requests are completed before initializing another request. 
Additionally or alternatively, a transaction identifier may be included in each sequence 

25 request packet. By utilizing such transaction identifiers, it may be possible to have 

potentially thousands of outstanding requests at any one time. It is a further advantage of the 
present inventive system and method to achieve greater scalability by utilizing pipelining. 

855064.1 



Attorney Docket No. 10001459-1 



9 



PATENT 



Nonetheless, it shall be appreciated that the present invention may utilize strong ordering 
techniques. 

FIGURE 2 illustrates an exemplary architecture employing the present invention. The 
network of FIGURE 2 comprises a plurality of nodes (201-208) and a plurality of switches 
5 (209A and 209B). It shall be appreciated that the architecture is merely exemplary and that 
an arbitrary number of nodes and switches may be utilized. Each node comprises a plurality 
of HW cards (HW cards 0 and HW cards 1) to facilitate connection to nodes 209A and 209B, 
respectively. The HW cards preferably provide an interface to the monotonic sequence 
generation fabric. The cards preferably provide lower level routines to request sequence 
10 numbers, issue or store sequence numbers for generator units, and/or initiate recovery 

measures. HW cards 0 of nodes 201-208 define logical connections from each node to switch 
209A. HW cards 1 of nodes 201-208 define logical connections from each node to switch 
209B. Accordingly, this embodiment employs a duplicated fabric configuration. 

Additionally, it shall be appreciated that a requesting node may be one of the primary 
15 or secondary generators. Utilizing the preceding discussed configuration, if an application 
upon node 204 requests a sequence number, HW card 0 of node 201 may increment the 
current value, DMA the value, and forward the value to HW card 0 of node 203. Node 203 
may increment the value and forward the value back to HW card 0 of node 204. In this 
manner, it is ensured that the current value is retained on both the primary and secondary 
20 generators. After receipt of the return value, HW card 0 may DMA the value for receipt by 
the appropriate application process. 

By way of example, the system may be initially configured to have node 204 as the 
primary generator and node 203 as the secondary generator. If node 201 issues a sequence 
number request and the system is utilizing the first fabric, node 201 may transmit the request 
25 via its HW card 0 through switch 209 A. After receipt of the request, HW card 0 of node 203 
may perform the increment operation, DMA operation, and forward operation through switch 
209 A. After receipt of the forwarded value, HW card 0 of node 204 may perform the DMA 
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operation and the forward operation through switch 209 A to HW card 0 of node 201. After 
receipt of the value, HW card 0 of node 201 may DMA the value for receipt by the 
appropriate application process. Upon failure (for example the failure of HW card 0 of node 
208), the system may be reconfigured by system management logic to utilize the secondary 
5 fabric defined by HW cards 1 and switch 209A. 

Alternatively, if both cards of the primary generator (node 204) fail, the manager 
process may detect the failure. The manager process may cause the secondary generator 
(node 203) to become the new primary generator, since node 203 has the current sequence 
number value. The manager process may preferably be implemented as middleware software 

10 that is independent of the applications utilizing the sequence number generation. Secondly, 
the manager process may select a new secondary generator. The new secondary generator 
receives the current value from node 203. Of course, the manager process communicates the 
identity of the new primary and secondary generators to the various nodes. At this point, all 
of the nodes except for node 204 are able to communicate with the new primary and 

15 secondary generators. Accordingly, process applications on these nodes are able to continue 
functions, since the sequence number generation remains available. Accordingly, the failure 
of both cards of node 204 only causes node 204 to cease to function. Thus, the present 
invention avoids a single point of failure, since failure of one node does not impede the 
remaining nodes of the network. 

20 It shall be appreciated that, in the event of unavailability of the secondary generator, 

identical processing may be utilized to select an alternative secondary generator and to 
provide the current sequence number to the newly designated secondary generator. It shall be 
further appreciated that the preceding architecture is merely one embodiment of the present 
invention. The present invention does not require any rigidly defined hardware 

25 implementation. The present invention is preferably implemented transparently within an 
existing network or fabric. For example, it is contemplated that the network of FIGURE 1 
could constitute a pre-existing configuration. The present invention may be employed upon 
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the pre-existing configuration with minimal modification by adding the sequence number 
generation mechanisms with connections to pre-existing switches 209 A and 209B. 
Accordingly, it is an advantage of the present invention to provide a highly available 
sequence number generation to a system of nodes with minimal modifications. 

5 As previously noted, the present invention preferably employs SN interfaces to 

provide sequence number generation to application processes in a transparent manner. 
Preferably, a library of user-space functions/routines is provided to access lower level 
sequence number routines of a selected device hardware/firmware implementation. The 
library may comprise the following exemplary functions/routines: 

10: : snbgn() - a function that is responsible for seeding the SN generator. Specifically, the seed 
operation selects a current sequence number that is sufficiently greater than a last known 
value so that it is highly probably that the current sequence number is beyond any value 
currently in flight. The routine may open a domain socket to a management thread and send a 
message containing the new SN value. The thread may contact the primary and secondary 

15j . generators to determine if they are operational and may "seed" the firmware. 

l -i snnew() - a function that is utilized by process applications to transparently generate a new 
SN value. The function call operates from the perspective of an application as an ordinary 
function call. The function may preferably be implemented as a light-weight call, as will be 
discussed in greater detail below. In the event of a time-out, the function may invoke a 
20 heavy-weight system call which may invoke sleeping. 

sncur() - a function that returns the current global SN value. 

snadj() - a function that allows the current global SN value to be incremented by an offset to 
insure that no sequence number replication occur after a recovery is completed. 
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It shall be appreciated that the use of a light weight system call such as snnew() is 
only one possible implementation. For example, similar functionality may be achieved 
utilizing a work request to the underlying hardware without requiring an application to 
perform a system call. Such an implementation would define a hardware work request which 
5 provides the same set of services and essentially the same output would occur. Alternatively, 
a system call may be implemented via a user application library call utilizing operating 
system bypass technology. Accordingly, it shall be appreciated that terms system call, light 
weight system call, and user application library call shall be interpreted equivalently. 

As previously noted, the sequence number generation may be employed in a wide 

10 variety of hardware configurations. Additionally, the configuration within a specific network 
or system may vary due to installation or removal of new resources, links, and/or the like. 
Accordingly, the present invention may employ a configuration process to establish primary 
and secondary generators. FIGURE 3 illustrates exemplary steps in such a configuration 
process. The configuration process may be initiated by a call to snbgnO- The function 

15 snbgn() is preferably implemented so that it communicates a seed message to a node 

management thread, instead of the local hardware/driver. In step 302, the node management 
thread may then initiate a primary and secondary generator election process. In step 303, the 
node management communicates a connectivity message to determine the status of all nodes 
within a cluster. The node management thread may then select a primary generator. After 

20 selecting the primary generator, the node management thread attempts a seed operation in 
step 304. Similarly, the node management thread may select a secondary generator and 
attempt a second seed operation in step 305. Of course, if any of the seed operations fail, the 
node management thread may select another generator and repeat the respective seeding step 
as many times as necessary to complete the selection process. After the primary and 

25 secondary generators have been selected and seeded, the ID of each generator may be 
broadcast to all connected nodes. 
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FIGURE 4 illustrates an exemplary SN operation within a light-weight system call. 
In step 401, the processing steps may begin by an application process performing a snnew() 
call. In step 402, the global state is examined. If the state in the firmware device is enabled 
and the fabric is viable, the process continues in step 403a. It shall be appreciated that the 
5 implementation utilizing firmware is only one embodiment of the present invention. The 
steps associated with firmware in this example could also be implemented in a variety of 
hardware structures. In step 403b, the global state is determined to be deficient and a return 
error message is generated for recovery purposes. In step 404, the operating processor is 
determined. The processor completion flag is cleared (step 405) and a PIO is performed to 

10 request a SN value from the fabric (step 406). Firmware sends an SN request comprising the 
primary ID to the primary generator (step 406-1). The primary generator receives the 
message, increments local value, and forwards a response to the secondary generator (step 
406-2). The secondary generator receives the message, records the SN value, and forwards 
the response to the initiating firmware (406-3). Firmware performs a DMA to place the value 

15 into memory and sets the processor completion flag (step 406-4). Concurrently to the 
underlying operations of steps 406-1 through 406-4, a spin loop is executed until the 
completion flag is set or the maximum spin count is exceeded (step 407). Upon detection of 
the completion flag, the processor breaks out of its spin loop and returns the value to the 
application process that performed the snnew() call. If the processor breaks from the spin 

20 loop after completing the maximum spin count, a heavy-weight call may be initiated as will 
be discussed in greater detail below. 

It shall be appreciated that the preceding steps facilitate superior data processing 
performance. Specifically, the hardware implementation of the SN request process allows a 
SN response value to be received in microseconds. By minimizing the latency of the system, 
25 it is not necessary to perform a sleep operation or perform a context switch out. The present 
invention avoids wasting processing cycles to store and retrieve data for caches associated 
with placing the calling application process in a sleep state and subsequently reawakening the 
process. 
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As mentioned earlier, the present invention may utilize a heavy-weight call in the rare 
event that a light-weight call is unsuccessful in obtaining a sequence number in a 
predetermined amount of time. In a heavy-weight call, the application process that made the 
initial sequence number call is placed into a sleep state. Accordingly, associated cache data is 
5 stored and retrieved as other processes utilize processor cycles during the sleep operation. 
Also, the heavy-weight call may notify the sequence number management thread that a 
problem has been encountered and recovery measures should be initiated. The management 
thread may attempt to determine the cause of the delay, such as a malfunctioning card, line, 
and/or the like and reconfigure accordingly. If the recovery is successful, the management 
1 0. thread may communicate successful recovery to the heavy-weight call process. The heavy- 
l weight call process may then re-request a sequence number. Upon receipt of the sequence 
number, the heavy-weight call may cause the application process to awaken from the sleep 
operation and communicate the received sequence number to the process. If the management 
;; : process is unable to initiate a recovery, the heavy-weight call may communicate an 
1 5=- appropriate error message to the calling application process. 

!. . When implemented in software, certain elements of the present invention are 

essentially the code segments to perform the necessary tasks. The program or code segments 
can be stored in a processor readable medium or transmitted by a computer data signal 
embodied in a carrier wave, or a signal modulated by a carrier, over a transmission medium. 

20 The "processor readable medium" may include any medium that can store or transfer 

information. Examples of the processor readable medium include an electronic circuit, a 
semiconductor memory device, a ROM, a flash memory, an erasable ROM (EROM), a floppy 
diskette, a compact disk CD-ROM, an optical disk, a hard disk, a fiber optic medium, a radio 
frequency (RF) link, etc. The computer data signal may include any signal that can propagate 

25 over a transmission medium such as electronic network channels, optical fibers, air, 
electromagnetic, RF links, etc. The code segments may be downloaded via computer 
networks such as the Internet, Intranet, etc. 
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FIGURE 5 illustrates computer system 500 adapted to use the present invention. 
Central processing unit (CPU) 501 is coupled to system bus 502. The CPU 501 may be any 
general purpose CPU such as an Intel Pentium processor. However, the present invention is 
not restricted by the architecture of CPU 501 as long as CPU 501 supports the inventive 
5 operations as described herein. Bus 502 is coupled to random access memory (RAM) 503, 
which may be SRAM, DRAM, or SDRAM. ROM 504 is also coupled to bus 502, which 
may be PROM, EPROM, or EEPROM. RAM 503 and ROM 504 hold user and system data 
and programs as is well known in the art. 

Bus 502 is also coupled to input/output (I/O) controller card 505, communications 
10 adapter card 511, user interface card 508, and display card 509. The I/O card 505 connects to 
storage devices 506, such as one or more of hard drive, CD drive, floppy disk drive, tape 
drive, to the computer system. Communications card 51 1 is adapted to couple the computer 
system 500 to a network 512, which may be one or more of telephone network, local (LAN) 
and/or wide-area (WAN) network, Ethernet network, and/or Internet network. User interface 
1 5 card 508 couples user input devices, such as keyboard 513 and pointing device 507, to the 
computer system 500. The display card 509 is driven by CPU 501 to control the display on 
display device 510. 

Although the present invention and its advantages have been described in detail, it 
should be understood that various changes, substitutions and alterations can be made herein 

20 without departing from the spirit and scope of the invention as defined by the appended 
claims. Moreover, the scope of the present application is not intended to be limited to the 
particular embodiments of the process, machine, manufacture, composition of matter, means, 
methods and steps described in the specification. As one of ordinary skill in the art will 
readily appreciate from the disclosure of the present invention, processes, machines, 

25 manufacture, compositions of matter, means, methods, or steps, presently existing or later to 
be developed that perform substantially the same function or achieve substantially the same 
result as the corresponding embodiments described herein may be utilized according to the 
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present invention. Accordingly, the appended claims are intended to include within their 
scope such processes, machines, manufacture, compositions of matter, means, methods, or 
steps. 
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